博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
完成登录功能,用session记住用户名
阅读量:5132 次
发布时间:2019-06-13

本文共 4236 字,大约阅读时间需要 14 分钟。

登录功能完成:

  1. js:设置return
  2. html:设置
    1. form
    2. input
    3. οnclick="return fnLogin()"
  3. py:
    1. @app.route设置methods
    2. GET
    3. POST
      1. 读取表单数据
      2. 查询数据库
        1. 用户名密码对:
          1. 记住用户名
          2. 跳转到首页
        2. 用户名密码不对:
          1. 提示相应错误。

session:

  1. 从`flask`中导入`session`
  2. 设置`SECRET_KEY`
  3. 操作字典一样操作`session`:增加用户名`session['username']=`username
    function myLogin() {        var oUname = document.getElementById("uname");        var oPass = document.getElementById("upass");        var oError = document.getElementById("error_box");        oError.innerHTML = "
    "; if (oUname.value.length < 6 || oUname.value.length > 20) { oError.innerHTML = "用户名为6-20位。"; return false; } else if((oUname.value.charCodeAt(0)>=48)&&(oUname.value.charCodeAt(0)<=57)){ oError.innerHTML="首位不能是数字"; return false; } else for(var i=0;i
    57)&&(oUname.value.charCodeAt(i)<97||oUname.value.charCodeAt(i)>122)){ oError.innerHTML="用户名只能包括字母和数字"; return false; } } if (oPass.value.length < 6 || oPass.value.length > 20) { oError.innerHTML = "密码为6-20位。"; return false; } return true; // window.alert("登录成功!"); }
    {% extends 'base.html'%}{% block title %}登录{% endblock %}{% block head %}    
    {% endblock %}{% block main %}

    登录

    username:
    password:
    {% endblock %}
    from flask import Flask,redirect,request,url_for,sessionfrom flask import render_templatefrom flask_sqlalchemy import SQLAlchemyimport configapp = Flask(__name__)app.config.from_object(config)db=SQLAlchemy(app)class User(db.Model):    __tablename__='user'    id=db.Column(db.Integer,primary_key=True,autoincrement=True)    username=db.Column(db.String(20),nullable=False)    password = db.Column(db.String(20), nullable=False)    nickname=db.Column(db.String(20))# db.create_all()#查询# user=User.query.filter(User.username=='mis1234').first()# print(user.id,user.username,user.password)#增加# user=User(username='mis1234',password='111111',nickname='l')# db.session.add(user)# db.session.commit()#增加# user=User(username='luk',password='123456',nickname='lu')# db.session.add(user)# db.session.commit()# 修改# user=User.query.filter(User.username=='mis1234').first()# user.password='12345678'# db.session.commit()## # 删除# user=User.query.filter(User.username=='mis1234').first()# db.session.delete(user)# db.session.commit()@app.route('/')def base():    return render_template('base.html')@app.route('/login/',methods=['GET','POST'])def login():    if request.method == 'GET':        return render_template('login.html')    else:        usern = request.form.get('username')        passw = request.form.get('password')        user = User.query.filter(User.username == usern).first()        if user:            if user.password==passw:                session['user']=usern                return redirect(url_for('shouye'))            else:                 return '密码错误。'        else:            return  '用户名不存在。'@app.route('/register/',methods=['GET','POST'])def register():    if request.method=='GET':        return render_template('register.html')    else:        usern=request.form.get('username')        nickn = request.form.get('nickname')        passw = request.form.get('password')        user=User.query.filter(User.username==usern).first()        if user:            return '用户名已存在。'        else:            user1=User(username=usern,password=passw,nickname=nickn)            db.session.add(user1)            db.session.commit()            return redirect(url_for('login'))#重定回向登录页面@app.route('/question/')def question():    return render_template('question.html')@app.route('/shouye/')def shouye():    return render_template('shouye.html')if __name__ == '__main__':    app.run(debug=True)
    import osSQLALCHEMY_DATABASE_URI='mysql+pymysql://root:@127.0.0.1:3306/mis_db?charset=utf8'SQLALCHEMY_TRACK_MODIFICATIONS=FalseSECRET_KEY=os.urandom(24)

     

     

转载于:https://www.cnblogs.com/lqx12/p/7879570.html

你可能感兴趣的文章
团队开发之个人博客八(4月27)
查看>>
发布功能完成
查看>>
【原】小程序常见问题整理
查看>>
C# ITextSharp pdf 自动打印
查看>>
【Java】synchronized与lock的区别
查看>>
django高级应用(分页功能)
查看>>
【转】Linux之printf命令
查看>>
关于PHP会话:session和cookie
查看>>
STM32F10x_RTC秒中断
查看>>
display:none和visiblity:hidden区别
查看>>
C#double转化成字符串 保留小数位数, 不以科学计数法的形式出现。
查看>>
牛的障碍Cow Steeplechase
查看>>
Zookeeper选举算法原理
查看>>
3月29日AM
查看>>
利用IP地址查询接口来查询IP归属地
查看>>
HTML元素定义 ID,Class,Style的优先级
查看>>
构造者模式
查看>>
http和https的区别
查看>>
Hbuild在线云ios打包失败,提示BuildConfigure Failed 31013 App Store 图标 未找到 解决方法...
查看>>
找到树中指定id的所有父节点
查看>>